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(54) Electronic television program guide system and method 



(57) An electronic programming guide (70) operates 
on a computing platform (12) associated with a televi- 
sion (40). The platform (12) accesses a program listing 
database (48) containing program listing information (6) 
for a plurality of television programs. The electronic pro- 
gramming guide (70) includes a profile database (80) 
that stores a viewer profile (84) and a suggest module 
(76) that is coupled to the profile database (80). The sug- 
gest module (76) accesses the viewer profile (84) and 



the program listing information (6) and, in response, 
generates a preferred schedule (100) according to the 
viewer profile (84) and the program listing information 
(6). The preferred schedule (100) indicates the desira- 
bility of a particular program relative to other programs. 
The electronic programming guide (70) may also be 
used to Instruct a recorder (20) to record a television 
program in accordance with the program listing informa- 
tion (6) and viewer input information that does not spec- 
ify broadcast information concerning the program. 
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Description 

TECHNICAL FIELD OF THE INVENTION 

This invention relates in general to the field of tele- 
vision, and more particularly to an electronic program- 
ming system and method. 

BACKGROUND OF THE INVENTION 

Many television viewers wish to select, schedule, 
and record their television viewing opportunities to en- 
hance the television viewing experience. To do this, 
many select programs for viewing after consulting a pa- 
per or electronic programming schedule to determine 
the programs available during particular time slots. Oth- 
ers change from channel to channel in an attempt to lo- 
cate desirable programming, with varying degrees of 
success. 

As the number of television channels and television 
programs continues to increase, allowing viewers to 
more intelligently select, schedule, and record their 
viewing opportunities becomes increasingly important. 
An existing technique for electronically accessing pro- 
gram scheduling information includes periodically 
downloading scheduling information and, in response to 
requests from the viewer, providing this scheduling in- 
formation in raw form to the viewer. Even though such 
techniques may allow the viewer to display only pro- 
grams of a particular genre, the viewer must still either 
inspect listing information for programs individually to 
make informed channel and program choices or waste 
time 'channel surfing" through the programs that are 
displayed. Because such techniques do not provide any 
direct channel tuning assistance, they are inadequate 
to meet the needs of many viewers. Moreover, prior 
techniques do not allow the viewer to restrict viewing of 
particular programs or programs having particular char- 
acteristics to certain viewers within the household, such 
as children, without first inspecting a program schedule 
to determine broadcast information for the programs, 
such as air dates, start times, stop times, and channels. 

Furthermore, electronic program guide (EPG) dis- 
plays that consider viewer preference information are 
subject to error, require the viewer to have some under- 
standing of the particular scoring algorithm used, are 
confusing to viewers that change from one EPG to an- 
other EPG, and do not allow for identification of pre- 
ferred program clustering, which severely limit the ability 
to accurately and efficiently plan quality viewing time. In 
addition, prior techniques for recording programs re- 
quire viewers to input detailed broadcast information, 
such as air dates, start times, stop times, and channels, 
or special program codes to record particular programs, 
are subject to error if a program to be recorded is longer 
than usual or expected, is preempted, is rescheduled, 
is changed from one channel to another channel, or oth- 
erwise varies from the expectations of the viewer in any 



manner, and do not allow viewers to record particular 
programs or types of programs that the viewers are most 
likely to enjoy based on viewer preferences or other in- 
put information that does not specify broadcast informa- 
5 tion for the programs. These and other inadequacies 
make prior techniques unsuitable for many viewers. 

SUMMARY OF THE INVENTION 

10 The present invention addresses the disadvantag- 
es and problems previously associated with television 
viewing and recording. 

According to one embodiment of the present inven- 
tion, an electronic programming guide operates on a 
15 computing platform that is associated with a television. 
The platform accesses a program listing database con- 
taining program listing information for a plurality of tele- 
vision programs. The electronic programming guide in- 
cludes a profile database that stores a viewer profile and 
20 a suggest module that is coupled to the profile database. 
The suggest module accesses the viewer profile and the 
program listing information and, in response, generates 
a preferred schedule according to the viewer profile and 
the program listing information. The preferred schedule 
25 indicates the desirability of a particular program relative 
to other programs. 

In another embodiment of the present invention, a 
method for recording a television program is performed 
on a computing platform associated with a television 
30 and a recorder. Viewer input information is received that 
does not specify broadcast information concerning the 
program. Program listing information for a plurality of 
programs is stored in a program listing database cou- 
pled to the platform. The program listing information is 
35 accessed and compared to the input information to gen- 
erate recording information for the program according 
to the comparison. The recording information for the 
program is communicated to the recorder to instruct the 
recorder to record the program. 
to The electronic programming system and method of 
the present invention provides a number of important 
technical advantages. The present invention generates 
profiles for one or more viewers that are used to score 
all available programming to determine which programs 
45 are most likely to appeal to the viewers. The resulting 
information is then provided in a simple and understand- 
able format that allows the viewers to more intelligently 
select, schedule, and record viewing opportunities with- 
out inspecting broadcast information for particular pro- 
50 grams. The program-based nature of the present inven- 
tion allows the viewer to tune to more desirable pro- 
gramming at any time during a viewing session and to 
record particular types of programs at any time before, 
during, or after a viewing session according to the view- 
55 er preference information used to establish the viewer 
profile. Furthermore, viewers need not block entire 
channels to restrict viewing of undesirable programs to 
certain viewers within the household, such as children. 
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In addition, the present invention allows viewers to 
record particular programs without providing or even 
having access to broadcast information such as air 
dates, start times, stop times, and channels. 

BRIEF DESCRIPTION OF THE DRAWINGS 

For a more complete understanding of the present 
invention and for further features and advantages there- 
of, reference is now made to the following description 
taken in conjunction with the accompanying drawings, 
in which: 

FIGURE 1 illustrates a JAVA-enabled television 
system according to the present invention; 
FIGURE 2 illustrates a JAVA-based operating hier- 
archy according to the present invention; 
FIGURE 3 illustrates an electronic programming 
guide according to the present invention; 
FIGURE 4 illustrates an exemplary preference tem- 
plate according to the present invention; and 
FIGURE 5 illustrates an exemplary preferred 
schedule according to the present invention; 
FIGURE 6 is a flow chart illustrating an exemplary 
method for selecting a program for viewing accord- 
ing to the present invention; and 
FIGURE 7 is a flow chart illustrating an exemplary 
method for recording a television program accord- 
ing to the present invention. 

DETAILED DESCRIPTION OF THE INVENTION 

FIGURE 1 illustrates a JAVA-enabled television 
system 2 that includes a JAVA-enabled television re- 
ceiver 10 that is associated with a television or other 
suitable display device 40 and a recorder 20, such as a 
video cassette recorder (VCR), video disk recorder, or 
other recording device suitable to record video and au- 
dio television signals. Receiver 10 includes a JAVA- 
based platform 12 that operates on one or more proc- 
essors 8, such as a digital signal processor (DSP) chip 
manufactured by TEXAS INSTRUMENTS INCORPO- 
RATED, an advanced reduced instruction set computer 
(RISC) machine (ARM), or any other suitable process- 
ing platform. Platform 12 is coupled to the Internet and 
associated sources of Internet information using a bidi- 
rectional link 14. In general, platform 12 provides a col- 
lection of application programming interfaces (APIs) 
that allow platform 12 to synchronize and integrate tel- 
evision signals and Internet information for display on 
television 40, to support JAVA applets or applications 
that provide interactive television programming, and to 
support JAVA applets or applications that provide a wide 
variety of functionalities related to television program- 
ming. In one embodiment, as discussed more fully be- 
low with reference to FIGURE 3, platform 12 supports 
an electronic programming guide JAVA applet or appli- 
cation that allows viewers to more intelligently select, 



schedule, and record viewing opportunities according to 
viewer profiles and information received using link 14. 
The structure of platform 12 is discussed more fully be- 
low with reference to FIGURE 2. Although JAVA is dis- 

5 cussed, any other platform independent programming 
language or other suitable programming language may 
be used without departing from the intended scope of 
the present invention. 

Link 14 may be any dedicated or switched connec- 

10 tion to a public switch telephone network (PSTN), an in- 
tegrated services digital network (ISDN), a coaxial cable 
network, a satellite or microwave link, or any other wire- 
less or wireline communications link suitable to couple 
platform 12 to the Internet. Although the Internet is dis- 

1* cussed, the present invention contemplates any global, 
regional, local, or other suitable computer network cou- 
pled to platform 1 2. Database server 46 coupled to the 
Internet accesses program listing database 48, which 
contains television programming information that is pe- 

20 riodically updated according to the operation of an or- 
ganization associated in some manner with server 46 
and database 48. In one embodiment, database 48 con- 
tains program listing information 6 for each program 
available for viewing within the next day, week, month, 

2S or other specified period from television signal source 
26, which may be any suitable cable television system 
(CATV), direct broadcast satellite system (DBS), regular 
satellite broadcast system, conventional television 
broadcast system, or other suitable system for providing 

30 television signals to receiver 10. 

For each program for which database 48 has listing 
information, program listing information 6 may include, 
without limitation: program dates; start times; stop 
times; a program length; program channels; program 

35 genres; a list of actors for the program; a list of sports 
teams to which the program may relate in some manner; 
keywords associated with the program that describe the 
program in some manner; a synopsis of the program; 
whether the program is a rerun, premiere, finale, mini- 

40 series, movie, special, or any other type of program; 
whether the program is a closed-captioned program; 
whether the program is in stereo; a Motion Picture As- 
sociation of America (MPAA) rating or other rating for 
the program; content information concerning nudity, 

45 adult situations, adult language, violence, or other any 
other type of content; and any other appropriate pro- 
gram listing information 6. An electronic programming 
guide (EPG) JAVA applet or application running on plat- 
form 1 2 periodically accesses database 48 using link 1 4 

so and server 46 to receive program listing information 6 
that allows'the EPG applet or application to provide tel- 
evision-related functionalities to viewers associated 
with receiver 10 and television 40, as discussed more 
fully below with reference to FIGURE 3. Although data- 

55 base 48 is discussed, the present invention contem- 
plates a suitable database integral to receiver 10 and 
periodically updated by one or more service providers 
external to receiver 10 using link 14, for example, daily, 
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weekly, or on any other periodic basis, to include pro- 
gram listing information 6 accessible to platform 12. 

Receiver 10 includes one or more tuner/decoders 
24 that couple to platform 1 2 using tuner/decoder con- 
trol line 22 and receive television signals from source 
26, either directly or through recorder 20. Recorder con- 
trol line 16 couples platform 12 to recorder controller 18 
that controls recorder 20 according to the operation of 
platform 12. One or more audio/video overlays 32 are 
coupled to platform 1 2 and coordinate the integration of 
television signals and Internet information in accord- 
ance with the operation of platform 12. A vertical blank- 
ing interval (VBI) decoder 28 coupled to tuner/decoder 
24 receives decoded television signals from tuner/de- 
coder 24, separates information from the VBI from the 
decoded television signals, for example, Intercast, 
closed-captioning, Teletext, or any other VBI informa- 
tion, and communicates the separated VBI information 
to platform 12. Tuner/decoder 24 also communicates 
the decoded television signals to audio/video overlays 
32 using television line 34. Audio/video overlays 32 
communicate outputs to video output 36 and audio out- 
put 38. 

In one embodiment, video output 36 is a super video 
(S-video) output with RCA jack cable support or any oth- 
er suitable video output. Audio output 38 may support 
any suitable combinaition of mono, stereo, surround, or 
other audio information. Video output 36 and audio out- 
put 38 are coupled to television 40, although the present 
invention contemplates video output 36 and audio out- 
put 38 integral to television 40 in accordance with the 
design of receiver 10 and system 2. Input device 42 in- 
cludes a remote control touch screen, mouse, keypad, 
or other suitable pointer to communicate infrared, elec- 
tronic, or other input signals to input receiver 44 of re- 
ceiver 10. Components of receiver 10 may be at one or 
more locations integral to or separate from television 40, 
such as a set top box, a network computer or other 
processing device, or any other component coupled to 
television 40. 

In operation of system 2, tuner/decoder 24 receives 
a television signal from source 26, either directly or us- 
ing recorder 20, and decodes the television signal as 
necessary or appropriate. In one embodiment, multiple 
tuner/decoders 24 are used to provide images suitable 
for a television picture display. Before, during, or after 
tuner/decoder 24 receives the television signal from 
source 26, a viewer associated with television 40 selects 
a particular channel for viewing, using input device 42 
or in any other suitable manner. Tuner/decoder 24 com- 
municates a decoded television signal corresponding to 
the selected channel to audio/video overlays 32 and VBI 
decoder 28, which in turn communicates the separated 
VBI information to platform 12. More or less simultane- 
ously, platform 12 receives Internet information using 
link 1 4 for integration with the decoded television signal 
according to a JAVA applet or application operating on 
platform 12. Also operating on platform 12 is an elec- 



tronic programming guide JAVA applet or application 
that provides various functionalities that allow viewers 
to more intelligently select, schedule, and record view- 
ing opportunities according to viewer profiles and infor- 

5 mation retrieved from database 48, as discussed more 
fully below with reference to FIGURE 3. 

Platform 12 contains channel mapping information 
that associates the television signal for each channel 
with one or more uniform resource locators (URLs) used 

10 for accessing Internet information corresponding to the 
channel. For example, if the viewer selects the CABLE 
NEWS NETWORK (CNN) for viewing, platform 12 might 
use the channel mapping information to associate the 
channel carrying CNN with a URL for an Internet web 

is site associated with CNN, such as httpy/www.cnn.com. 
Using the URL and other appropriate information, plat- 
form 12 retrieves the associated web page using Inter- 
net link 14. Audio/video overlays 32 integrate the web 
page, any appropriate VBI information received from 

20 VBI decoder 28, and the television signal for the select- 
ed channel received from tuner/decoder 24 according 
to the JAVA applet or application operating on platform 
12 that controls the integration of this information. Au- 
dio/video overlays 32 then communicate the integrated 

25 information to television 40 using video output 36 and 
audio output 38 for viewing. 

Typical integration of television signals and Internet 
information might result visually as the regular television 
broadcast in a first display area on television 40 and the 

30 Internet information in a second display area on televi- 
sion 40. In one embodiment, platform 1 2 allows the first 
and second display areas to be moved, sized, merged, 
blended, overlayed, or manipulated according to the 
corresponding JAVA applet or application to provide 

35 more sophisticated collective displays than were possi- 
ble using prior systems. The present invention contem- 
plates communicating a URL or other Internet informa- 
tion corresponding to a channel from source 26 using 
the VBI associated with the particular television signal 

40 for the channel. VBI decoder 24 would decode and com- 
municate this information to platform 12, which would 
then access the appropriate URL using Internet link 14 
to retrieve Internet information for integration with the 
television signal. Other suitable arrangements for ob- 

45 tairiing a URL or other information necessary to allow 
platform 12 to integrate television signals and Internet 
information are contemplated, without departing from 
the intended scope of the present invention. 

Since the web page that platform 1 2 accesses using 

so the URL and integrates with the television signals for the 
corresponding channel may provide information relating 
to the subject matter of the television program, the view- 
er is able to interact with one medium to conveniently 
access a great deal of information concerning a topic. 

55 in addition, the Internet information that platform 1 2 syn- 
chronizes and integrates with the corresponding televi- 
sion signals may include information regarding other re- 
lated web sites, an associated chat room in which the 
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viewer might discuss the program with other viewers 
during the program, or any other Internet information. 
During a commercial break in the program, information 
regarding the advertised product might be retrieved 
from a web site associated with the product and syn- 
chronously and integrally displayed along with the com- 
mercial. In addition, as discussed more fully below with 
reference to FIGURE 3, platform 12 supports a JAVA- 
based electronic programming guide (EPG) that allows 
one or more viewers to more intelligently select, sched- 
ule, or record viewing opportunities according to viewer 
profiles and program listing information 6 to enhance the 
television viewing experience. 

FIGURE 2 illustrates an exemplary JAVA-based op- 
erating hierarchy 50 for system 2 and platform 12 that 
includes a number of levels, each containing a collection 
of hardware, software, or both hardware and software 
suitable to perform the functions of system 2 and plat- 
form 12. First level 51 includes conventional television- 
related hardware 52, such as recorder controller 18, tun- 
er/decoder 24, VBI decoder 28, video output 36, audio 
output 38, input receiver 44, and any other suitable hard- 
ware and software associated with receiver 10, recorder 
20, and television 40. Second level 53 of hierarchy 50 
includes one or more interactive television protocols 54, 
for example, Digital AudioA/ideo Interactive Decoder 
(DAVID) and Interactive Communications Applications 
Protocol (ICAP). Third level 55 of hierarchy 50 includes 
a basic JAVA operating system 56 with JAVA RUN- 
TIME, which implements the JAVA VIRTUAL MACHINE 
to provide various low level JAVA capabilities such as 
windowing, networking, and file management, together 
with appropriate JAVA extensions that augment basic 
JAVA APIs and associated classes according to the 
functionalities associated with platform 1 2. One such 
functionality, as discussed more fully below, is support- 
ing an electronic programming guide JAVA applet or ap- 
plication that allows viewers to select, schedule, and 
record viewing opportunities according to viewer pro- 
files and program listing information 6 retrieved from da- 
tabase 48. 

Fourth level 57 includes a JAVA toolkit 58 having a 
collection of APIs 60 that cooperate with JAVA operating 
system 56 to allow JAVA applets 64 and applications 62 
in fifth level 59 to perform functionalities associated with 
JAVA applets 64 and applications 62. In one embodi- 
ment, APIs 60 of toolkit 58 allow platform 12 to support 
JAVA applets 64 downloaded from the Internet over link 
1 4, JAVA applications 62 installed locally on receiver 1 0 
or any processing platform associated with receiver 10, 
or any other appropriate JAVA program that uses the 
television-related functionalities of APIs 60. Since toolkit 
58 and APIs 60 are designed to support any appropriate 
JAVA applet 64 or application 62, the viewer is not lim- 
ited to applets 64 or applications 62 from particular con- 
tent developers, but may download any JAVA applet 64 
or install any JAVA application 62 that provides the de- 
sired functionality without concern regarding compatibil- 



ity with platform 12. Furthermore, toolkit 58 allows de- 
velopers to write applets 64 and applications 62 that pre- 
sume an ability on the part of platform 12 to integrate 
television signals and Internet information, to provide in- 

5 teractive television programming, to allow viewers to 
more intelligently select, schedule, or record viewing op- 
portunities according to viewer profiles and program list- 
ing information 6, and to support any other suitable tel- 
evision-related functionality. 

10 in one embodiment, each API 60 includes a collec- 
tion of JAVA functions and supporting classes that are 
related to a particular task or combination of associated 
tasks and extend the basic JAVA APIs discussed above. 
For example, a control API 60 contains classes that sup- 

15 port functions to integrate television signals into JAVA 
applets 64 and applications 62 as discussed above. 
Control API 60 also includes classes that control video 
and audio properties associated with television 40, for 
example, and not by way of limitation: controlling televi- 

20 sion overlay operations, such as color overlay keying to 
overlay JAVA animations; setting channel numbers; set- 
ting the position, width, and height of the television sig- 
nal video component within an integrated display; turn- 
ing the video or audio on or off; freezing or unfreezing 

25 the video; setting video brightness, contrast, color, or 
tint; setting audio volume, balance, bass, and treble; and 
any other suitable property related to the information 
presented on television 40. 

In addition, control API 60 may include classes that 

30 define mapping between channel nurhbers, identifiers, 
and associated URLs; associate electronic program 
guides with channels; represent data streams transmit- 
ted in the VBI associated with channels; update the in- 
tegrated displays presented on television 40 according 

35 to changes in content on the associated channels; and 
perform any other activity associated with the incorpo- 
ration of television signals into the JAVA environment of 
platform 12. For example, with respect to updating inte- 
grated displays, if a program switches to a commercial 

40 break, control API 60 may cause a web page or other 
Internet information associated with the advertised 
product to be displayed on television 40 in synchroniza- 
tion with the displayed commercial to provide additional 
product information or an opportunity to order or com- 

^5 ment on the product. URLs and other appropriate infor- 
mation communicated in the VBI may cooperate to allow 
platform 12 to provide mapping functionality. Control 
API 60 also includes classes for controlling various op- 
erations of recorder 20, for example, starting, stopping, 

50 playing, recording, pausing, fast-forwarding, and re- 
winding. The present invention contemplates any class- 
es suitable to allow control API 60 and platform 12 to 
support television-related JAVA applets 64 and applica- 
tions 62, regardless of the content developer or partic- 

55 ular operation. 

Toolkit 58 may include a datacast API 60 that in- 
cludes classes to support access to data communicated 
along with the television signals from source 26, such 
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as Intercast, closed-captioning, Teletext, and other VBI 
information. A showlet API 60 of toolkit 58 includes 
classes that support interactive television programming, 
such as for shopping, advertising, polling, distance 
learning, participation in game shows, banking, and any 
other interactive programming. As discussed above, 
since toolkit 58 and associated APIs 60 of platform 12 
support JAVA applets 64 and applications 62 having any 
appropriate operation, the number of interactive pro- 
gramming opportunities that platform 1 2 and system 2 
provide is virtually limitless. 

Toolkit 58 also includes an electronic programming 
guide (EPG) API 60 that contains classes for querying 
for, retrieving, and manipulating program listing informa- 
tion 6 contained in program listing database 48, con- 
structing and modifying viewer profiles according to 
viewer preferences, constructing electronic scheduling 
displays according to viewer profiles and selected pro- 
gram listing information 6, and providing other desirable 
functionalities that allow viewers to more intelligently se- 
lect, schedule, and record viewing opportunities. An 
EPG applet or application 70 that operates using EPG 
API 60 and other APIs 60 of toolkit 58 in accordance 
with the present invention is discussed more fully below 
with reference to FIGURE 3. As shown in FIGURE 2, 
JAVA operating system 56 and toolkit 58 implement plat- 
form 12 for running JAVA applets 64 and applications 
62 iri fifth level 59 of hierarchy 50. Although hierarchy 
50 is discussed with discrete levels that run on proces- 
sor 8 of receiver 10, the present invention contemplates 
one or more levels that are integral to one another or 
levels that are distributed to run on separate compo- 
nents of receiver 10 or system 2. Interactive television 
protocols 54, JAVA operating system 56, and toolkit 58 
with associated APIs 60 may be referred to collectively 
as platform 12. 

As an example of the operation of APIs 60, consider 
an EPG applet 70 that is downloaded from the Internet 
to run on platform 1 2. In one embodiment, as discussed 
below with reference to FIGURE 3, functionality associ- 
ated with EPG applet 70 includes recording a television 
program that is scheduled for broadcast on some un- 
specified date in the future. After EPG applet 70 is down- 
loaded and begins to run, EPG applet 70 calls EPG API 
60 and other APIs 60 as appropriate to accomplish spe- 
cific tasks. To record a particular program, for example, 
EPG applet 70 might call a routine associated with EPG 
API 60 that queries program listing database 48 to de- 
termine the air date, start time, stop time, and channel 
on which the particular program is scheduled for broad- 
cast, passing a program name or other program identi- 
fier to EPG API 60. EPG API 60 might then periodically 
query database 48 until the date of broadcast and the 
current date are identical. After determining that the pro- 
gram is scheduled for broadcast on the current date, 
EPG API 60 might call a routine associated with control 
API 60 that sets recorder 20 to record, passing the start 
time or other information appropriate for initiating re- 



cording of the program. Similar operation might occur to 
stop the recording or perform any other suitable func- 
tionality that EPG API 60 and other APIs 60 of toolkit 58 
support. Since the calls from EPG applet 70 to APIs 60 

5 and between APIs 60 are resolved at run time in the 
JAVA environment associated with platform 12, platform 
12 is able to support virtually any appropriate EPG ap- 
plet 70, which provides an important technical advan- 
tage. Although EPG applet 70 is discussed, the above 

10 discussion would apply equally to a suitable EPG appli- 
cation 70. 

FIGURE 3 illustrates JAVA-based electronic pro- 
gram guide (EPG) 70, which may run on platform 1 2 and 
processor 8 as a JAVA applet 64 downloaded from the 

15 Internet over link 1 4 or as a JAVA application 62 installed 
locally on receiver 10 or an associated processing plat- 
form. In one embodiment, EPG 70 includes a control 
module 72, a profile module 74, a suggest module 76, 
and a schedule module 78 that cooperate to provide var- 

20 bus EPG functionalities, as discussed below. According 
to operation of control module 72, profile module 74, 
, suggest module 76, schedule module 78, and any other 
appropriate components, EPG 70 uses EPG API 60 to 
access program listing information 6 in database 48 in 

25 cooperation with database server 46, as discussed 
above with reference to FIGURE 1. The present inven- 
tion contemplates storing program listing information 6 
locally at receiver 1 0 and periodically updating program 
listing information 6 to replace or combine with access- 

30 ing database 48 using link 1 4. In general, EPG 70 allows 
a viewer to more intelligently select, schedule, and 
record viewing opportunities according to program list- 
ing information 6 and a viewer profile associated with 
the viewer. 

35 Control module 72 interfaces with the components 
of platform 12 and system 2 as necessary to retrieve 
program listing information 6. For example, if program 
listing information 6 for a particular program is desired, 
control module 72 might call a routine associated with 
40 EPG API 60 to retrieve the desired program listing in- 
formation 6 in database 48 corresponding to the pro- 
gram, passing suitable information concerning the pro- 
gram and the desired program listing information 6 to 
EPG API 60. After the appropriate program listing infor- 
ms mation 6 is returned, control module 72 communicates 
program listing information 6 to other components of 
EPG 70, such as profile module 74 or suggest module 
76, according to the operation of these components. 
Control module 72 also coordinates communications 
so between profile module 74, suggest module 76, and 
schedule module 78 as appropriate. In one embodi- 
ment, control module 72 prompts the viewer for and re- 
ceives a viewer identity in response to the viewer turning 
on television 40 or in some other manner accessing the 
55 resources of EPG 70. 

Profile module 74 receives preference information 
from one or more viewers associated with receiver 10, 
such as multiple viewers within a family that owns JAVA- 
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enabled television system 2, and constructs, builds, or 
otherwise generates corresponding viewer profiles 84 
for storage in profile database 80. The present invention 
contemplates each viewer having a separate viewer 
profile 84, one or more viewers, such as children, having 
a combined viewer profile 84, or any other suitable ar- 
rangement with respect to viewer profiles 84. Further- 
more, one or more viewer profiles 84 may be added, 
deleted, modified, inactivated, reactivated, or otherwise 
manipulated at any time according to operation of EPG 
70. Profile database 80 may include one or more data- 
bases, files, lists, or other arrangement of information at 
one or more locations that are integral to or separate 
from receiver 10. 

In one embodiment, profile database 80 also con- 
tains one or more preference templates 82 that profile 
module 74 may access and communicate to a viewer 
using control module 72 to receive preference informa- 
tion from the viewer For example, EPG 70 may com- 
municate one or more preference templates 82 to a 
viewer in response to the viewer pointing to, clicking on, 
or otherwise selecting a profile set-up option that EPG 
70 displays on television 40 as part of a windowing menu 
associated with EPG 70. The viewer might then select 
a particular preference template 82 to begin construct- 
ing or modifying viewer profile 84 associated with the 
viewer. The present invention contemplates viewers in- 
teracting with EPG 70 in any suitable manner to select 
preference templates 82. EPG 70 may also allow the 
viewer to use input device 42 to hyperlink between tem- 
plates 82 or viewer profiles 84 displayed on television 
40 according to the operation of EPG 70 and particular 
needs. 

Preference templates 82 stored in profile database 
80 may include, without limitation: a genre template 82 
that lists possible program genres, for example, drama, 
horror, comedy, romance, or other program genre; an 
actor template 82 that lists actors that may appear in a 
program; a sports team template 82 that lists sports 
teams to which a program may relate in some manner, 
for example, if the program is an athletic contest, a doc- 
umentary, or other sports-related programming; a key- 
word template 82 that lists keywords that may describe 
the program in some manner, for example, non-stop, 
heart-warming, exciting, romantic, or other suitable key- 
words; and any other suitable preference template 82 
suitable for constructing viewer profile 84 according to 
preference information associated with the correspond- 
ing viewer Multiple preference templates 82 may in- 
clude the same or similar options that result in the viewer 
providing the same or similar preference information. 
For example, a viewer might select •educational" as a 
preference using both genre template 82 and keyword 
template 82. In one embodiment, options given the 
viewer in connection with templates 82 correspond to 
program listing information 6 that database 48 may con- 
tain currently or at some point in the future, depending 
on the particular programs for which database 48 con- 



tains program listing information 6 and other suitable 
factors. 

For each option presented to the viewer in connec- 
tion with preference templates 82, preference templates 

5 82 allow the viewer to provide ranking information that 
EPG 70 uses to generate viewer profile 84 and provide 
enhanced viewing opportunities according to viewer 
profile 84, as discussed more fully below. Referring to 
FIGURE 4, genre preference template 82 includes op- 

10 tions 86 and corresponding rankings 88 in any suitable 
presentation format that is viewable on television 40. In 
one embodiment, the viewer provides a ranking 88 for 
each option 86 to indicate the desirability of program- 
ming associated with option 86 according to any suitable 

15 scale, standard, or other criteria. For example, for each 
option 86, template 82 might include any number of cir- 
cles, boxes, or other locations on template 82 that each 
correspond to a qualitative assessment of the degree to 
which the viewer will likely enjoy programming associ- 

20 ated with option 86. 

To provide rankings 88 for options 86, the viewer 
would simply point to, click on, or otherwise indicate the 
appropriate locations using input device 42 or in any oth- 
er suitable manner. Each location may also be associ- 

2S ated with a numerical value or weight that quantifies the 
assessment of the viewer for purposes of scoring pro- 
grams according to viewer profile 84, as discussed more 
fully below. For example, if "comedy" option 86 is highly 
preferable to the viewer, the viewer might indicate the 

30 last location to the right in FIGURE 4 to provide ranking 
88, which might then have a "10" weight. Similarly, if 
"drama" option 86 is mildly preferable to the viewer, the 
viewer might indicate the next to last location to the right 
to provide ranking 88, which might then have a "3" 

35 weight. An option 86 with respect to which the viewer is 
neutral might get ranking 88 with a "0" weight, an option 
86 mildly unpref erable to the viewer might receive rank- 
ing 88 with a "-3" weight, and an option 86 highly un- 
preferable to the viewer might receive ranking 88 with a 

40 "-10" weight. The present invention contemplates any 
evaluation orweighting technique suitable toallow view- 
ers to provide rankings 88 for some or all options 86 as- 
sociated with template 82. 

EPG 70 may allow the viewer to hyperlink to dis- 

45 plays that provide additional descriptions, examples, or 
other suitable information by selecting a particular op- 
tion 86 using input device 82. Genre template 82 may 
include an exit window 90 allowing the viewer to exit 
genre template 82 and return to a preference template 

so menu or any other appropriate menu after providing 
preference information in accordance with genre tem- 
plate 82. Although genre template 82 is discussed, the 
present discussbn applies equally to any other suitable 
preference templates 82, such as actor template 82, 

55 sports team template 82, or keyword template 82. After 
the viewer has provided preference information to EPG 
70 using the appropriate templates 82, profile module 
74 stores the preference information for the viewer in 
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profile database 80 as a new or modified viewer profile 
84 for the viewer. EPG 70 may generate and store view- 
er profiles 84 for each viewer associated with system 2, 
may combine one or more viewer profiles 84 in accord- 
ance with particular needs, or may generate viewer pro- s 
files 84 in any other manner according to preference in- 
formation that one or more viewers provide to EPG 70. 

Suggest module 76 accesses program listing infor- 
mation 6 in database 48, directly or using control module 
72, and viewer profiles 84 in profile database 80 to gen- 
erate a preferred programming schedule that allows 
viewers to more intelligently select programs that may 
be desirable for viewing or recording. FIGURE 5 illus- 
trates an exemplary preferred schedule 100 that corre- 
sponds to the available television programming be- 
tween 8:00p.m. and 1 2:00p.m. on a particular date. Pre- 
ferred schedule 100 includes channel programming 
102, 104, 106, 108, 110, and 112 corresponding to first, 
second, third, fourth, fifth, and sixth channels, respec- 
tively, although the present invention contemplates any 
number of channels. Channel programming 102, 104, 
1 06, 1 08, 1 1 0, and 1 1 2 are referred to generally as chan- 
nel programming 102 unless otherwise indicated. Each 
program for which preferred schedule 100 has channel 
programming 102 may fill some or all of one or more 
time slots 114, which are each thirty minutes long in the 
example shown in FIGURE 5, yielding the brick-like ap- 
pearance of preferred schedule 100. Button 118 on pre- 
ferred schedule 1 1 8 allows the viewer to hyperlink or es- 
tablish a connection to a preference template menu or 
a display of viewer profile 84. Preferred schedule 100 is 
referred to as including channel programming 1 02, scor- 
ing indicators 1 1 6 and program scores used to generate 
scoring indicators 1 1 6, as discussed below, and any oth- 
er suitable information associated with preferred sched- 
ule 100. EPG 70 may temporarily or more or less per- 
manently store preferred schedule 100 at any suitable 
location. 

Using viewer profile 84 and an appropriate scoring 
algorithm 77, suggest module 76 generates a color cod- 
ed, numerical, or other scoring indicator 116 for each 
program for which channel programming 102 and pre- 
ferred schedule 100 contain programming information. 
Additional textual or other suitable information concern- 
ing the program might be associated with scoring indi- 
cator 116. In general, scoring indicator 116 visually in- 
dicates to the viewer a degree of desirability likely to be 
associated with a corresponding program, based on 
viewer profile 84 for the viewer. For example, scoring 
indicator 1 1 6 may include color or shading that overlays 
textual information concerning the program, such as 
bright green for a highly desirable program, pale green 
for a mildly desirable program, yellow for a program that 
is not likely to be relatively desirable or relatively unde- 
sirable, pale red for a mildly undesirable program, and 
bright red for a highly undesirable program. Any other 
suitable color gradations may be used. In the alterna- 
tive, channel programming 102 for desirable programs 



might have clear backgrounds for the textual informa- 
tion, channel programming 102 for programs that are 
neither desirable nor undesirable might have gray back- 
grounds, and programming information 102 for undesir- 
able programs might be entirely blacked out over appro- 
priate time slots 114. Although the present invention 
contemplates scoring indicators 116 in any suitable for- 
mat, in one embodiment the use of coloring provides im- 
portant technical advantages, as discussed more fully 
below. 

In operation of suggest module 76, control module 
72 communicates the viewer identity for the viewer and 
program listing information 6 for some or all available 
programs to suggest module 76. In response, suggest 
module 76 accesses the corresponding viewer profile 
84 in profile database 80. For each program, suggest 
module 76 uses scoring algorithm 77 to generate a pro- 
gram score indicating the desirability of the program to 
the viewer based on viewer profile 84 and program list- 
ing information 6. For example, assume program listing 
information 6 for a particular program indicated to scor- 
ing algorithm 77 that the program genre was comedy, 
that the program featured actor Bill Cosby, that a key- 
word associated with the program was "fascinating," 
and that the program was a closed-captioned rerun 
starting at 10:00p.m. and ending at 10:30p.m. on the 
current date on the fourth channel/Ranking 88 for "com- 
edy 0 genre option 86 in viewer profile 84 might be a nu- 
meric value, such as "10" or other suitable value, indi- 
cating that the viewer strongly prefers comedy pro- 
grams. Similarly, ranking 88 for "Bill Cosby" actor option 
86 might be a "3" or other value indicating that the viewer 
mildly prefers Bill Cosby programs, and ranking 88 for 
"fascinating" keyword option 86 might be a "0" or other 
value indicating that the viewer is neutral regarding pro- 
grams with which "fascinating" keyword option 86 might 
be associated. 

Still referring to the same example, scoring algo- 
rithm 77 might add, average, or otherwise manipulate 
rankings 88 for the program to determine a score for the 
program to indicate the degree to which the viewer is 
likely to enjoy the program, considering all applicable 
information within program listing information 6 and 
viewer profile 84, which is likely to be relatively high for 
this example. In one embodiment, scoring module 77 
determines a score for every program for which pre- 
ferred schedule 100 contains channel programming 
102. For programs having scores in a highest percentile 
range, such as in the highest fifteen percent of scores 
or any other specified range, suggest module 76 may 
associate the appropriate colored scoring indicator 116, 
such as green, clear, or other suitable scoring indicator 
116, with the program within preferred schedule 100 to 
overlay textual information concerning the program. For 
programs with scores in a middle percentile range, sug- 
gest module 76 may associate a yellow, gray, or other 
scoring indicator 116 with the program. For programs 
having scores in a lowest percentile range, suggest 
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module may associate red with the program, black out 
the program and associated textual information from 
preferred schedule 100, or provide scoring indicator 116 
to the viewer in any other manner to indicate relative 
undesirability of the programs. 5 

According to the particular scoring algorithm 77, the 
particular scheme for scoring indicators 116, program 
listing information 6, and viewer profile 84, the viewer is 
able to consult preferred schedule 100 to intelligently 
select from among myriad available viewing opportuni- 
ties. Since preferred schedule 100 is color coded ac- 
cording to the degree to which programs are likely to be 
enjoyable, the viewer need not have any understanding 
or knowledge of scoring algorithm 77, the scores deter- 
mined for any program or the relationship between the 
scores determined for any collection of programs, or any 
other aspect of the manner in which suggest module 76 
generates preferred schedule 100. The viewer may 
specify any suitable correspondence between percen- 
tile ranges for program scores and the colors used for 
scoring indicators 116 to customize EPG 70 in accord- 
ance with particular needs. Scoring algorithm 77 may 
be replaced or modified without altering the functionality 
of EPG 70 from the perspective of the viewer, because 
the mapping between the desirability of a program and 
scoring indicator 116 is consistent, such that the viewer 
always receives channel programming 102 in a format 
the viewer can readily understand and appreciate. 

Referring again to FIGURE 5, in time slot 114 be- 
tween 10:00p.m. and 10:30p.m., channel programming 
104 for the second channel, channel programming 108 
for the fourth channel, and channel programming 112 
for the sixth channel all have clear scoring indicators 
116, which would overlay textual information for corre- 
sponding programs, indicating that the programs on all 
three of these channels are likely to be enjoyable to the 
viewer. In contrast, the first, third, and fifth channels 
have channel programming 102, 106, and 110, respec- 
tively, having gray or black scoring indicators 1 1 6, as the 
case may be, which indicates that programs on these 
channels during this time slot 114 are not likely to be 
enjoyable to the particular viewer. As a result, if the view- 
er consults preferred schedule 100 with respect to this 
time slot 114, the viewer can readily make a determina- 
tion regarding the channels to select, providing an im- 
portant technical advantage. In addition, preferred 
schedule 100 allows the viewer to make more intelligent 
decisions concerning which time slots 114 are likely to 
be most suitable for enjoyable viewing in accordance 
with the arrangement of scoring indicators 116. For ex- 
ample, if the concentration of clear scoring indicators 
116 for desirable programs is relatively high in one or 
more time slots 114, the viewer may plan viewing times 
for the viewer or other viewers within the household ac- 
cordingly. 

In one embodiment, EPG 70 allows the viewer to 
point to, click on, or otherwise select channel program- 
ming 102 for a particular program to hyperlink or estab- 



lish any suitable connection to a display that provides 
additional factual, descriptive, or other information relat- 
ing to the program, the associated program listing infor- 
mation 6, the score that scoring algorithm 77 generated 
for the program, the percentile rank or range for the pro- 
gram associated with the program score, or any other 
suitable information, in any combination. EPG 70 may 
allow the viewer to further hyperlink from this display to 
other displays providing further information concerning 
selected program listing information 6. For example, if 
the first display for the program includes a list of actors 
appearing in the program, the viewer may point to, click 
on, or otherwise select the name of an actor to hyperlink 
or establish a connection to a second display providing 
biographical information for the actor, other programs in 
which the actor appears, or any other suitable informa- 
tion concerning the actor. EPG 70 may allow the viewer 
to point to, click on, or otherwise select a particular time 
slot 114 to receive the program score and other infor- 
mation for some or all programs airing within at least a 
portion of time slot 114, in descending order from high- 
est to lowest score or any other suitable order. The 
present invention contemplates any technique for pro- 
viding the viewer with access to program-related infor- 
mation to allow the vie wer to select program viewing and 
recording opportunities more intelligently to enhance 
the television-related experience. The viewer may pro- 
vide an appropriate URL at any time to access the in- 
formation discussed above from Internet information 
sources, such as a web page associated with an actor 
or program. 

Furthermore, EPG 70 allows the viewer to change 
from one channel, whether or not the channel is current- 
ly airing a relatively desirable program, to another chan- 
nel that is currently airing a relatively desirable program 
at any time during a viewing session. In one embodi- 
ment, the viewer presses the "channel up" button or oth- 
erwise provides an indication using input device 42 that 
the viewer wishes to change channels. In response, 
EPG 70 changes to another channel, for example, the 
channel airing the program having the highest score rel- 
ative to the other programs currently airing on other 
channels, while bypassing channels that are not cur- 
rently airing a program satisfying the preferences of the 
viewer currently in effect. Since the viewer can modify 
the corresponding viewer profile 84 at any time or can 
select a particular program at any time according to pref- 
erences the viewer may provide at any time, the viewer 
need not consult any printed programming guides to 
make a viewing decision, which is an important technical 
advantage of the present invention. 

For example, referring again to preferred schedule 
100 in FIGURE 5, if the viewer is currently viewing a 
program on the first channel during time slot 114 be- 
tween 10:00p.m. and 10:30p.m. and presses the "chan- 
nel up" button on input device 42, EPG 70 would cause 
receiver lo to tune to the sixth channel currently airing a 
program that is likely to be desirable, as indicated by the 
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clear scoring indicator 116 associated with channel pro- 
gramming 1 1 2 for the sixth channel during time slot 1 1 4. 
Similarly, if the viewer again presses the "channel up" 
button, EPG 70 would cause receiver 10 to tune to the 
fourth channel, which is also airing a program having a 
clear scoring indicator 116. In this manner, the viewer is 
able to bypass the program airing on the fifth channel, 
which is not as likely to be enjoyable to the viewer, as 
indicated by the gray scoring indicator 116 associated 
with channel programming 110 for the fifth channel. 

EPG 70 may also use additional criteria specified 
by the viewer or otherwise in determining which channel 
to tune to in response to an indication from the viewer 
that a channel change is desired. For example, if more 
than one channel is airing a program with a clear scoring 
indicator 116 during time slot 114, EPG 70 may cause 
receiver 10 to tune to the channel airing the program 
that started most recently. In this case, for the 10:00p. 
m. to 10:30p.m. time slot 114, the fourth channel would 
be tuned to first, the sixth channel second, and the sec- 
ond channel third. EPG 70 may use other information to 
determine which channel to select, for example, the 
channel airing the program with the highest score, the 
channel airing a program that is not a rerun, or any other 
information. The present invention contemplates any 
suitable technique for selecting one or more alternative 
channels for viewing at any time during a viewing ses- 
sion. 

Since EPG 70 performs a channel selection proc- 
ess that is program-based rather than channel-based, 
the selection process dynamically adapts as programs 
aired on the various channels change. For example, 
during time slot 114 between 10:30p.m. and 11:00p.m., 
EPG 70 might still preferentially tune receiver 10 to the 
fourth channel, but would not tune to the sixth channel 
for which channel programming 112 now includes a 
black scoring indicator 116 corresponding to a low like- 
lihood that the viewer will enjoy the program. EPG 70 
may preferentially select channels for viewing during 
time slot 114 according to any appropriate combination 
of program listing information 6 retrieved from database 
48 using EPG API 60, link 14, and database server 46. 

EPG 70 also allows a viewer to control viewing hab- 
its and opportunities for other viewers, such as children 
in a household, due to the program-based nature of 
EPG-70 and the functionality that-EPG-70-provides: In 
one embodiment, the parent may filter, block, or other- 
wise prevent a child from viewing a particular program 
or type of program that has associated program listing 
information 6 satisfying a predetermined criterion or set 
of criteria. For example, if the parent wanted to prevent 
the child from viewing any program of the "horror" genre, 
the parent could enter the corresponding preference in- 
formation using profile module 74 or otherwise, and the 
child might be required to provide identity information to 
EPG 70 to access television 40 when the parent was 
not present. If the child accessed system 2 while HOME 
BOX OFFICE was airing Halloween, EPG 70 would not 



allow the child to tune to the channel corresponding to 
HOME BOX OFFICE at that time, but would later permit 
the child to tune to the same channel while HOME BOX 
OFFICE was airing The Sound of Music or other rela- 

5 tively preferable programming. The parent could also 
limit the total daily viewing of the child with respect to 
programs with program listing information 6 satisfying 
selected characteristics entered using profile module 74 
or otherwise. For example, the parent might use EPG 

10 70 to limit the daily viewing of programs of the "cartoon- 
genre to two hours, after which EPG 70 would not allow 
the child to select a channel that was currently airing a 
program of that genre. The program-based nature of 
EPG 70 provides an important technical advantage over 

is previous systems for providing programming informa- 
tion. 

Another important technical advantage of the 
present invention involves the ability to record programs 
using recorder 20 in accordance with viewer profiles 84, 

20 program listing information 6, or both viewer profiles 84 
and program listing information 6, without relying on the 
viewer to provide information concerning air dates, start 
times, stop times, or channels for the programs, referred 
to collectively as broadcast information. Since EPG 70 

25 has access to the resources of database 48 and pro- 
gram listing information 6, if the viewer provides EPG 
70 with the title or another suitable identifier for a pro- 
gram, EPG 70 can use EPG API 60 and other compo- 
nents of platform 12 and receiver 10 to cause recorder 

30 20 to record the program regardless of the date, time, 
or channel on which the program will air. For example, 
if the viewer specifies recording of all episodes of 
M*A*S*H or another series, EPG 70 will cause M*A*S*H 
to be recorded even if the channel airing M*A*S*H 

35 changes, the time at which M*A*S*H is aired changes, 
or the length of the M*A*S*H program changes because 
the program is a season premiere or for any other rea- 
son, because EPG 70 continues to maintain access to 
the appropriate program listing information 6 in data- 

40 base 48. Eliminating the need for the viewer to provide 
broadcast information is an important technical advan- 
tage. 

Similarly, the viewer can cause recorder 20 to 
record all programs associated with particular keyword 

45 or other options 86, such as "James Bond" or another 
suitable keyword option 86 r specify that-reruns of-a pro- 
gram that is otherwise to be recorded are not to be re- 
corded, or specify the recordingof programs in any other 
suitable manner using EPG 70. Scoring algorithm 77 of 

so suggest module 76 may also determine scores for each 
program available to be recorded according to program 
listing information 6 and an appropriate profile 84 stored 
in profile database 80. If the score for a particular pro- 
gram exceeds a predetermined threshold specified by 

55 the viewer or otherwise, EPG 70 may cause the program 
to be recorded even though the viewer had no knowl- 
edge that the program would be airing or even that the 
program existed. EPG 70 may record programs using 
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one or more recorders 20. For example, if recorders 20 
are VCRs and EPG 70 supports multiple viewer profiles 
84, EPG 70 may cause a program that is relatively de- 
sirable for a particular viewer according to associated 
viewer profile 84 to be recorded using recorder 20 cor- 
responding to the particular viewer. The recording of 
programs may be periodically modified by inactivating 
or removing selected viewer profiles 84 from database 
80 in accordance with particular needs. 

Schedule module 78 of EPG 70 provides a conven- 
tional programming schedule in accordance with pro- 
gram listing information 6, but does not include informa- 
tion concerning viewer preferences or other information 
associated with or determined according to viewer pro- 
files 84. For example, a viewer may point to, click on, or 
select schedule module 78 using a menu display asso- 
ciated with EPG 70 or in any other suitable manner. In 
response, EPG 70 may display channel information 102 
for various channels over one or more time slots 114, 
as shown in FIGURE 5 and discussed above with refer- 
ence to preferred schedule 100, except that scoring in- 
dicators 116 are absent from the programming sched- 
ule. The present invention contemplates combining the 
programming schedule associated with schedule mod- 
ule 78 and preferred schedule 100 associated with sug- 
gest module 76 in any appropriate manner. Although 
EPG 70 is discussed with respect to platform 12, the 
present invention contemplates EPG 70 running on any 
platform suitable to support JAVA-based operation of 
EPG 70. The present invention further contemplates 
one or more modules of EPG 70 being integral to one 
or more other modules or distributed to operate on 
processing platforms external to platform 12. 

FIGURE 6 is a flow chart illustrating an exemplary 
method for selecting a program for viewing according to 
the operation of EPG 70. The method begins at step 
200, where the viewer provides viewer preference infor- 
mation to EPG 70 using one or more preference tem- 
plates 82 and input device 42 or in any other manner. 
At step 202, profile module 74 receives the viewer pref- 
erence information, either directly or through control 
module 72, in the form of rankings 88 corresponding to 
preference options 86. As discussed more fully above, 
options 86 may include genre options 86, actor options 
86, sports team options 86, keyword options 86, or any 
other suitable options 86. Profile module 74 generates 
viewer profile 84 for the viewer at step 204 and, at step 
206, stores viewer profile 84 in profile database 80. In 
one embodiment, viewer profile 84 includes rankings 88 
for each preference option 86 to provide an indication 
of the relative desirability to the viewer of programming 
that is associated with the particular option 86. Suggest 
module 76, control module 72, or another suitable com- 
ponent of EPG 70 receives viewer input at step 207, 
which may include the viewer turning on television 40, 
accessing EPG 70 in some manner, or otherwise indi- 
cating that the viewer wishes to view television program- 
ming. 



At step 208, suggest module 76 accesses viewer 
profile 84 in profile database 80 and program listing in- 
formation 6 in program listing database 48, in coopera- 
tion with EPG API 60, link 14, and database server 46. 
5 Suggest module 76 may access one or more local da- 
tabases periodically updated to contain program listing 
information 6 to replace or combine with accessing da- 
tabase 48. Suggest module 76 may access program list- 
ing information 6 for all programs airing on a particular 
date, within one or more time slots 114, or any other set 
of programs. At step 210, suggest module 76 and asso- 
ciated scoring algorithm 77 calculate, determine, or oth- 
erwise generate a program score for each program ac- 
cording to viewer profile 84 and program listing informa- 
tion 6. At step 212, suggest module 76 generates pre- 
ferred schedule 100 having channel programming 102 
for appropriate time slots 114. In one embodiment, a 
scoring indicator 116 is associated with each program 
for which preferred schedule contains channel program- 
ming 102, in the form of a color overlaying textual infor- 
mation concerning the program or in any other format. 

Suggest module 76 may receive an indication at 
step 214 that a program change is appropriate. For ex- 
ample, the indication may include the viewer pressing a 
"channel up" button on input device 42 or providing any 
other suitable indication. Alternatively, if the viewer is a 
child, the parent may have instructed EPG 70 to prevent 
the child from viewing programming of a particular gen- 
re. The indication may include the child selecting a chan- 
nel currently airing a program having the undesirable 
genre or the ending of a desirable program airing on a 
channel that subsequently begins to air a program hav- 
ing the undesirable genre. If the indication is received 
at step 214, suggest module 76 selects a program at 
step 216 that is more likely to be desirable, according to 
program scores for the other programs for which pre- 
ferred schedule 100 contains channel programming 
102, and the method ends. If the indication is not re- 
ceived at step 21 4, viewing continues as before and the 
method ends. Steps 200 through 216 may be repeated 
as many times and in any relative order as appropriate 
to allow viewers to modify viewer profiles 84, to select 
an alternative program for viewing during a viewing ses- 
sion, or to otherwise implement any of the functionalities 
that EPG 70 supports. 

FIGURE 7 is a flow chart illustrating an exemplary 
method for recording a television program according to 
the operation of EPG 70. The method begins at step 
300, where the viewer provides viewer input information 
to EPG 70. In one embodiment, the input information 
may include a program identifier for the program to be 
recorded, such as a title for the program, any preference 
option 86 discussed above, or any combination of a pro- 
gram identifier and one or more preference options 86. 
Since EPG 70 is program-based, the input information 
need not include broadcast information, such as an air 
date, start time, stop time, or channel. Since EPG 70 is 
able to cause recorder 20 to record any program using 
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a program identifier for the program, without information 
from the viewer regarding the air date, start time, stop 
time, or channel, preference information may not be 
necessary, in the alternative, the viewer may instruct 
EPG 70 to cause recorder 20 to record all previously 
unidentified programs satisfying viewer profile 84, in 
which case input information would include at least 
some viewer preference information. Suggest module 
76 receives the input information at step 302, directly or 
through control module 72 or any other suitable compo- 
nent of EPG 70. 

Suggest module 76 accesses program listing infor- 
mation 6 at step 304 stored locally or in database 48 
using EPG API 60, link 14, and database server 46. At 
step 306, suggest module 76 compares the input infor- 
mation, such as the program identifier or viewer profile 
84 generated using the preference information for the 
viewer, with program listing information 6 in database 
48. In accordance with the comparison performed at 
step 306, suggest module 76 generates recording infor- 
mation for the program at step 308. For example, if a 
program for which database 48 contains program listing 
information 6 satisfies a predetermined threshold score 
associated with viewer profile 84, then suggest module 
76 may generate the recording information for the pro- 
gram to cause the program to be recorded. 

The recording information may include any instruc- 
tion or set of instructions suitable to cause recorder 20 
to record the program, such as an air date, start time, 
stop time, channel, or other information relating to the 
airing of the program. The present invention contem- 
plates the recording information being an instruction to 
EPG API 60, control API 60, or another component of 
platform 1 2 to initiate recording of the program. At step 
310, suggest module 76, control module 72, or another 
component of EPG 70 communicates the recording in- 
formation for the program to EPG API 60, control API 
60, or any other appropriate component of platform 12 
or system 2 to instruct recorder 20 to record the pro- 
gram, and the method ends. The present invention con- 
templates the steps illustrated in FIGURES 6 and 7 co- 
operating in any suitable manner to allow one or more 
viewers to more intelligently select, schedule, and 
record viewing opportunities according to operation of 
EPG 70 and system 2. 

Although the present invention has been described 
with several embodiments, a plethora of changes, sub- 
stitutions, variations, alterations, transformations, and 
modifications may be suggested to one skilled in the art, 
and it is intended that the present invention encompass 
such changes, substitutions, variations, alterations, 
transformations, and modifications as fall within the spir- 
it and scope of the teachings disclosed herein. 



Claims 

1. An electronic programming guide for computing 



platform associated with a television, the platform 
operable to access a program listing database con- 
taining program listing information for a plurality of 
television programs, the electronic programming 
5 guide comprising: 

a profile database for storing a viewer profile; 
and 

a suggest module coupled to the profile data- 
10 base for accessing the viewer profile and the 

program listing information and, in response, to 
generate a preferred schedule according to the 
viewer profile and the program listing informa- 
tion, the preferred schedule indicative of the de- 
* 5 stability of a particular program relative to other 

programs. 

2. The electronic programming guide of Claim 1 , fur- 
ther comprising a profile module for receiving view- 

20 er preference information and, in response, for gen- 
erating the viewer profile. 

3. The electronic programming guide of Claim 2, 
wherein the profile module is operable to provide a 

25 preference template to the viewer for receiving the 
viewer preference information. 

4. The electronic programming guide of any preceding 
Claim, wherein the viewer profile includes a ranking 

30 corresponding to an option selected from the group 
consisting of: 

a genre option; 
an actor option; 
35 a sports team option; and 

a.keyword option. 

5. The electronic programming guide of any preceding 
Claim, wherein the suggest module comprises a 

40 scoring algorithm for generating a score for the pro- 
gram according to the viewer profile and the pro- 
gram listing information. 

6. The electronic programming guide of Claim 5, 
45 wherein the suggest module is further operable to 

associate a color with the program in the preferred 
schedule according to the score for the program. 

7. The electronic programming guide of Claim 5 or 
50 Claim 6, wherein the suggest module is further op- 
erable to select a channel for viewing according to 
the score for the program. 

8. The electronic programming guide of any preceding 
55 Claim, wherein the viewer profile comprises an op- 
tion that corresponds to an undesirable program, 
the suggest module operable to prevent viewing of 
the undesirable program in accordance with the op- 
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tion and program listing information for the undesir- 
able program. 

9. A method performed on a computing platform that 
is associated with a television for providing function- 
ality associated with an electronic programming 
guide, the method comprising: 

storing a viewer profile in a profile database; 
accessing the viewer profile in the profile data- 
base and program listing information stored in 
a program listing database for a plurality of tel- 
evision programs; and 

generating a preferred schedule in accordance 
with the viewer profile and the program listing 
information, the preferred schedule indicative 
of the desirability of a particular program rela- 
tive to other programs. 

1 0. The method of Claim 9, further comprising the steps 
of: 

receiving viewer preference information; and 
generating the viewer profile according to the 
viewer preference information. 

11. The method of Claim 10, further comprising the step 
of providing a preference template to the viewer for 
receiving the viewer preference information. 

12. The method of any of Claims 9 to 11, wherein the 
step of storing the viewer profile comprises storing 
a viewer profile having a ranking corresponding to 
an option selected from the group consisting of: 

a genre option; 

an actor option; 

a sports team option; and 

a keyword option. 

13. The method of any of Claims 9 to 12, further com- 
prising the step of generating a score for the pro- 
gram according to the viewer profile and the pro- 
gram listing information. 

14. The method of Claim 1 3, further comprising the step 
of associating a color with the program in the pre- 
ferred schedule according to the score for the pro- 
gram. 

15. The method of Claim 13 or Claim 14, further com- 
prising the step of selecting a channel for viewing 
according to the score for the program. 

16. The method of any of Claims 9 to 15, wherein the 
step of storing the viewer profile having storing a 
viewer profile comprises an option that corresponds 
to an undesirable program, and preventing viewing 



of the undesirable program according to the option 
and program listing information for the undesirable 
program. 

s 17. A method performed on a computing platform that 
is associated with a television and a recorder for re- 
cording a television program, the method compris- 
ing: 

10 receiving viewer input information; 

accessing program listing information for a plu- 
rality of programs stored in a program listing da- 
tabase coupled to the platform; 
comparing the input information with the pro- 
's gram listing information; 

generating recording information for the pro- 
gram in accordance with the comparison; and 
communicating recording information for the 
program to the recorder to instruct the recorder 
20 to record the program. 

18. The method of Claim 1 7, wherein the step of receiv- 
ing viewer input information comprises receiving 
viewer input information comprising a program title. 

25 

19. The method of Claim 17, wherein the step of receiv- 
ing viewer input information comprising receiving 
viewer input information comprises viewer prefer- 
ence information that includes a ranking corre- 

30 sponding to an option selected from the group con- 
sisting of: 

a genre option; 
an actor option; 
35 a sports team option; and 

a keyword option. 

20. The method of Claim 1 9, further comprising the step 
of generating a score for the program according to 

40 the viewer preference information and the program 
listing information. 
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